<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>Async</title>
    <link rel="stylesheet" type="text/css" href="static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            Async
        
    </div>
<ul><li class="active"><a href="index.html">0.Async</a></li><li><a href="html/0.editor.html">0.editor</a></li><li><a href="html/0.module.html">0.module</a></li><li><a href="html/1.ES2015.html">1.ES2015</a></li><li><a href="html/2.Promise.html">2.Promise</a></li><li><a href="html/3.Node.html">3.Node</a></li><li><a href="html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="html/5.REPL.html">5.REPL</a></li><li><a href="html/6.NodeCore.html">6.NodeCore</a></li><li><a href="html/7.module&NPM.html">7.module&NPM</a></li><li><a href="html/8.Encoding.html">8.Encoding</a></li><li><a href="html/9.Buffer.html">9.Buffer</a></li><li><a href="html/10.fs.html">10.fs</a></li><li><a href="html/11.Stream-1.html">11.Stream-1</a></li><li><a href="html/11.Stream-2.html">11.Stream-2</a></li><li><a href="html/11.Stream-3.html">11.Stream-3</a></li><li><a href="html/11.Stream-4.html">11.Stream-4</a></li><li><a href="html/12-Network-2.html">12-Network-2</a></li><li><a href="html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="html/12.Network-1.html">12.Network-1</a></li><li><a href="html/13.tcp.html">13.tcp</a></li><li><a href="html/14.http-1.html">14.http-1</a></li><li><a href="html/14.http-2.html">14.http-2</a></li><li><a href="html/15.compress.html">15.compress</a></li><li><a href="html/16.crypto.html">16.crypto</a></li><li><a href="html/17.process.html">17.process</a></li><li><a href="html/18.yargs.html">18.yargs</a></li><li><a href="html/19.cache.html">19.cache</a></li><li><a href="html/20.action.html">20.action</a></li><li><a href="html/21.https.html">21.https</a></li><li><a href="html/22.cookie.html">22.cookie</a></li><li><a href="html/23.session.html">23.session</a></li><li><a href="html/24.express-1.html">24.express-1</a></li><li><a href="html/24.express-2.html">24.express-2</a></li><li><a href="html/24.express-3.html">24.express-3</a></li><li><a href="html/24.express-4.html">24.express-4</a></li><li><a href="html/25.koa-1.html">25.koa-1</a></li><li><a href="html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="html/27.react-1.html">27.react-1</a></li><li><a href="html/27.react-2.html">27.react-2</a></li><li><a href="html/27.react-3.html">27.react-3</a></li><li><a href="html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="html/27.react-6.html">27.react-6</a></li><li><a href="html/28.react-mobx.html">28.react-mobx</a></li><li><a href="html/28.redux-0.html">28.redux-0</a></li><li><a href="html/28.redux-1.html">28.redux-1</a></li><li><a href="html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="html/29.mongodb-2.html">29.mongodb-2</a></li><li><a href="html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="html/30.cms-10-dva.html">30.cms-10-dva</a></li><li><a href="html/30.cms-11-front.html">30.cms-11-front</a></li><li><a href="html/31.cms-12-api.html">31.cms-12-api</a></li><li><a href="html/31.cms-13-front.html">31.cms-13-front</a></li><li><a href="html/31.cms-14-deploy.html">31.cms-14-deploy</a></li><li><a href="html/32.ant.html">32.ant</a></li><li><a href="html/33.redis.html">33.redis</a></li><li><a href="html/34.unittest.html">34.unittest</a></li><li><a href="html/35.jwt.html">35.jwt</a></li><li><a href="html/36.websocket-1.html">36.websocket-1</a></li><li><a href="html/36.websocket-2.html">36.websocket-2</a></li><li><a href="html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="html/38.chat-3.html">38.chat-3</a></li><li><a href="html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="html/38.chat.html">38.chat</a></li><li><a href="html/38.chat2.html">38.chat2</a></li><li><a href="html/38.chat2.html">38.chat2</a></li><li><a href="html/39.crawl-0.html">39.crawl-0</a></li><li><a href="html/39.crawl-1.html">39.crawl-1</a></li><li><a href="html/39.crawl-2.html">39.crawl-2</a></li><li><a href="html/40.deploy.html">40.deploy</a></li><li><a href="html/41.safe.html">41.safe</a></li><li><a href="html/42.test.html">42.test</a></li><li><a href="html/43.nginx.html">43.nginx</a></li><li><a href="html/44.enzyme.html">44.enzyme</a></li><li><a href="html/45.docker.html">45.docker</a></li><li><a href="html/46.elastic.html">46.elastic</a></li><li><a href="html/47.oauth.html">47.oauth</a></li><li><a href="html/48.wxpay.html">48.wxpay</a></li><li><a href="html/49.nunjucks.html">49.nunjucks</a></li><li><a href="html/50.ketang.html">50.ketang</a></li><li><a href="html/index.html">index</a></li><li><a href="html/51.typescript.html">51.typescript</a></li><li><a href="html/52.UML.html">52.UML</a></li><li><a href="html/53.design.html">53.design</a></li><li><a href="html/index.html">index</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. 异步">1. 异步</a></li><li><a href="#t12.高阶函数">2.高阶函数</a><ul><li><a href="#t22.1 可以用于批量生成函数">2.1 可以用于批量生成函数</a></li><li><a href="#t32.2 可以用于需要调用多次才执行的函数">2.2 可以用于需要调用多次才执行的函数</a></li></ul></li><li><a href="#t43. 异步编程的语法目标，就是怎样让它更像同步编程,有以下几种">3. 异步编程的语法目标，就是怎样让它更像同步编程,有以下几种</a></li><li><a href="#t54. 回调">4. 回调</a></li><li><a href="#t65 回调的问题">5 回调的问题</a><ul><li><a href="#t75.1 异常处理">5.1 异常处理</a></li><li><a href="#t85.2 回调地狱">5.2 回调地狱</a></li></ul></li><li><a href="#t96. 异步流程解决方案">6. 异步流程解决方案</a><ul><li><a href="#t106.1 事件发布/订阅模型">6.1 事件发布/订阅模型</a></li><li><a href="#t116.2 哨兵变量">6.2 哨兵变量</a></li><li><a href="#t126.3 Promise/Deferred模式">6.3 Promise/Deferred模式</a></li><li><a href="#t136.4 生成器Generators/ yield">6.4 生成器Generators/ yield</a><ul><li><a href="#t146.4.1 生成器的使用">6.4.1 生成器的使用</a></li><li><a href="#t156.4.2 Co">6.4.2 Co</a></li></ul></li></ul></li><li><a href="#t166.5 Async/ await">6.5 Async/ await</a><ul><li><a href="#t176.5.1 Async的优点">6.5.1 Async的优点</a></li><li><a href="#t186.5.2 async 函数的实现">6.5.2 async 函数的实现</a></li></ul></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. &#x5F02;&#x6B65;">1. &#x5F02;&#x6B65; <a href="#t01. &#x5F02;&#x6B65;"> # </a></h2>
<ul>
<li>&#x6240;&#x8C13;&quot;&#x5F02;&#x6B65;&quot;&#xFF0C;&#x7B80;&#x5355;&#x8BF4;&#x5C31;&#x662F;&#x4E00;&#x4E2A;&#x4EFB;&#x52A1;&#x5206;&#x6210;&#x4E24;&#x6BB5;&#xFF0C;&#x5148;&#x6267;&#x884C;&#x7B2C;&#x4E00;&#x6BB5;&#xFF0C;&#x7136;&#x540E;&#x8F6C;&#x800C;&#x6267;&#x884C;&#x5176;&#x4ED6;&#x4EFB;&#x52A1;&#xFF0C;&#x7B49;&#x505A;&#x597D;&#x4E86;&#x51C6;&#x5907;&#xFF0C;&#x518D;&#x56DE;&#x8FC7;&#x5934;&#x6267;&#x884C;&#x7B2C;&#x4E8C;&#x6BB5;,&#x6BD4;&#x5982;&#xFF0C;&#x6709;&#x4E00;&#x4E2A;&#x4EFB;&#x52A1;&#x662F;&#x8BFB;&#x53D6;&#x6587;&#x4EF6;&#x8FDB;&#x884C;&#x5904;&#x7406;&#xFF0C;&#x5F02;&#x6B65;&#x7684;&#x6267;&#x884C;&#x8FC7;&#x7A0B;&#x5C31;&#x662F;&#x4E0B;&#x9762;&#x8FD9;&#x6837;&#x3002;</li>
</ul>
<p><img src="http://img.zhufengpeixun.cn/asyncfunc1.png" alt=""></p>
<p>&#x8FD9;&#x79CD;&#x4E0D;&#x8FDE;&#x7EED;&#x7684;&#x6267;&#x884C;&#xFF0C;&#x5C31;&#x53EB;&#x505A;&#x5F02;&#x6B65;&#x3002;&#x76F8;&#x5E94;&#x5730;&#xFF0C;&#x8FDE;&#x7EED;&#x7684;&#x6267;&#x884C;&#xFF0C;&#x5C31;&#x53EB;&#x505A;&#x540C;&#x6B65;&#x3002;</p>
<p><img src="http://img.zhufengpeixun.cn/syncfunc.png" alt=""></p>
<h2 id="t12.&#x9AD8;&#x9636;&#x51FD;&#x6570;">2.&#x9AD8;&#x9636;&#x51FD;&#x6570; <a href="#t12.&#x9AD8;&#x9636;&#x51FD;&#x6570;"> # </a></h2>
<p>&#x51FD;&#x6570;&#x4F5C;&#x4E3A;&#x4E00;&#x7B49;&#x516C;&#x6C11;&#xFF0C;&#x53EF;&#x4EE5;&#x4F5C;&#x4E3A;&#x53C2;&#x6570;&#x548C;&#x8FD4;&#x56DE;&#x503C;</p>
<h3 id="t22.1 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x6279;&#x91CF;&#x751F;&#x6210;&#x51FD;&#x6570;">2.1 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x6279;&#x91CF;&#x751F;&#x6210;&#x51FD;&#x6570; <a href="#t22.1 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x6279;&#x91CF;&#x751F;&#x6210;&#x51FD;&#x6570;"> # </a></h3>
<pre><code>let toString = Object.prototype.toString;
let isString = function (obj) {
  return toString.call(obj) == `[object String]`;
}
let isFunction = function (obj) {
  return toString.call(obj) == `[object Function]`;
}
let isType = function (type) {
  return function (obj) {
    return toString.call(obj) == `[object ${type}]`;
  }
}
</code></pre><h3 id="t32.2 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x9700;&#x8981;&#x8C03;&#x7528;&#x591A;&#x6B21;&#x624D;&#x6267;&#x884C;&#x7684;&#x51FD;&#x6570;">2.2 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x9700;&#x8981;&#x8C03;&#x7528;&#x591A;&#x6B21;&#x624D;&#x6267;&#x884C;&#x7684;&#x51FD;&#x6570; <a href="#t32.2 &#x53EF;&#x4EE5;&#x7528;&#x4E8E;&#x9700;&#x8981;&#x8C03;&#x7528;&#x591A;&#x6B21;&#x624D;&#x6267;&#x884C;&#x7684;&#x51FD;&#x6570;"> # </a></h3>
<pre><code>let after = function(times,task){
  return function(){
    if(times--==1){
      return task.apply(this,arguments);
    }
  }
}
let fn = after(3,function(){
  console.log(3);});
fn();
</code></pre><h2 id="t43. &#x5F02;&#x6B65;&#x7F16;&#x7A0B;&#x7684;&#x8BED;&#x6CD5;&#x76EE;&#x6807;&#xFF0C;&#x5C31;&#x662F;&#x600E;&#x6837;&#x8BA9;&#x5B83;&#x66F4;&#x50CF;&#x540C;&#x6B65;&#x7F16;&#x7A0B;,&#x6709;&#x4EE5;&#x4E0B;&#x51E0;&#x79CD;">3. &#x5F02;&#x6B65;&#x7F16;&#x7A0B;&#x7684;&#x8BED;&#x6CD5;&#x76EE;&#x6807;&#xFF0C;&#x5C31;&#x662F;&#x600E;&#x6837;&#x8BA9;&#x5B83;&#x66F4;&#x50CF;&#x540C;&#x6B65;&#x7F16;&#x7A0B;,&#x6709;&#x4EE5;&#x4E0B;&#x51E0;&#x79CD; <a href="#t43. &#x5F02;&#x6B65;&#x7F16;&#x7A0B;&#x7684;&#x8BED;&#x6CD5;&#x76EE;&#x6807;&#xFF0C;&#x5C31;&#x662F;&#x600E;&#x6837;&#x8BA9;&#x5B83;&#x66F4;&#x50CF;&#x540C;&#x6B65;&#x7F16;&#x7A0B;,&#x6709;&#x4EE5;&#x4E0B;&#x51E0;&#x79CD;"> # </a></h2>
<ul>
<li>&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x5B9E;&#x73B0;</li>
<li>&#x4E8B;&#x4EF6;&#x76D1;&#x542C;</li>
<li>&#x53D1;&#x5E03;&#x8BA2;&#x9605;</li>
<li>Promise/A+ &#x548C;&#x751F;&#x6210;&#x5668;&#x51FD;&#x6570;</li>
<li>async/await</li>
</ul>
<h2 id="t54. &#x56DE;&#x8C03;">4. &#x56DE;&#x8C03; <a href="#t54. &#x56DE;&#x8C03;"> # </a></h2>
<p>&#x6240;&#x8C13;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#xFF0C;&#x5C31;&#x662F;&#x628A;&#x4EFB;&#x52A1;&#x7684;&#x7B2C;&#x4E8C;&#x6BB5;&#x5355;&#x72EC;&#x5199;&#x5728;&#x4E00;&#x4E2A;&#x51FD;&#x6570;&#x91CC;&#x9762;&#xFF0C;&#x7B49;&#x5230;&#x91CD;&#x65B0;&#x6267;&#x884C;&#x8FD9;&#x4E2A;&#x4EFB;&#x52A1;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x5C31;&#x76F4;&#x63A5;&#x8C03;&#x7528;&#x8FD9;&#x4E2A;&#x51FD;&#x6570;</p>
<pre><code>fs.readFile(&apos;&#x67D0;&#x4E2A;&#x6587;&#x4EF6;&apos;, function (err, data) {
  if (err) throw err;
  console.log(data);
});
</code></pre><p> &#x8FD9;&#x662F;&#x4E00;&#x4E2A;&#x9519;&#x8BEF;&#x4F18;&#x5148;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;(error-first callbacks),&#x8FD9;&#x4E5F;&#x662F;Node.js&#x672C;&#x8EAB;&#x7684;&#x7279;&#x70B9;&#x4E4B;&#x4E00;&#x3002;</p>
<h2 id="t65 &#x56DE;&#x8C03;&#x7684;&#x95EE;&#x9898;">5 &#x56DE;&#x8C03;&#x7684;&#x95EE;&#x9898; <a href="#t65 &#x56DE;&#x8C03;&#x7684;&#x95EE;&#x9898;"> # </a></h2>
<h3 id="t75.1 &#x5F02;&#x5E38;&#x5904;&#x7406;">5.1 &#x5F02;&#x5E38;&#x5904;&#x7406; <a href="#t75.1 &#x5F02;&#x5E38;&#x5904;&#x7406;"> # </a></h3>
<pre><code>try{
  //xxx
}catch(e){//TODO}
</code></pre><p> &#x5F02;&#x6B65;&#x4EE3;&#x7801;&#x65F6;<code>try catch</code>&#x4E0D;&#x518D;&#x751F;&#x6548;</p>
<pre><code>let async = function(callback){
  try{
    setTimeout(function(){
      callback();
    },1000)
  }catch(e){
    console.log(&apos;&#x6355;&#x83B7;&#x9519;&#x8BEF;&apos;,e);
  }
}

async(function(){
  console.log(t);
});
</code></pre><p> &#x56E0;&#x4E3A;&#x8FD9;&#x4E2A;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x88AB;&#x5B58;&#x653E;&#x4E86;&#x8D77;&#x6765;&#xFF0C;&#x76F4;&#x5230;&#x4E0B;&#x4E00;&#x4E2A;&#x4E8B;&#x4EF6;&#x73AF;&#x7684;&#x65F6;&#x5019;&#x624D;&#x4F1A;&#x53D6;&#x51FA;,try&#x53EA;&#x80FD;&#x6355;&#x83B7;&#x5F53;&#x524D;&#x5FAA;&#x73AF;&#x5185;&#x7684;&#x5F02;&#x5E38;&#xFF0C;&#x5BF9;callback&#x5F02;&#x6B65;&#x65E0;&#x80FD;&#x4E3A;&#x529B;&#x3002;</p>
<p>Node&#x5728;&#x5904;&#x7406;&#x5F02;&#x5E38;&#x6709;&#x4E00;&#x4E2A;&#x7EA6;&#x5B9A;&#xFF0C;&#x5C06;&#x5F02;&#x5E38;&#x4F5C;&#x4E3A;&#x56DE;&#x8C03;&#x7684;&#x7B2C;&#x4E00;&#x4E2A;&#x5B9E;&#x53C2;&#x4F20;&#x56DE;&#xFF0C;&#x5982;&#x679C;&#x4E3A;&#x7A7A;&#x8868;&#x793A;&#x6CA1;&#x6709;&#x51FA;&#x9519;&#x3002;</p>
<pre><code>async(function(err,callback){
  if(err){
    console.log(err);
  }
});
</code></pre><p>&#x5F02;&#x6B65;&#x65B9;&#x6CD5;&#x4E5F;&#x8981;&#x9075;&#x5FAA;&#x4E24;&#x4E2A;&#x539F;&#x5219;</p>
<ul>
<li>&#x5FC5;&#x987B;&#x5728;&#x5F02;&#x6B65;&#x4E4B;&#x540E;&#x8C03;&#x7528;&#x4F20;&#x5165;&#x7684;&#x56DE;&#x8C03;&#x51FD;&#x6570;</li>
<li>&#x5982;&#x679C;&#x51FA;&#x9519;&#x4E86;&#x8981;&#x5411;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x4F20;&#x5165;&#x5F02;&#x5E38;&#x4F9B;&#x8C03;&#x7528;&#x8005;&#x5224;&#x65AD;<pre><code>let async = function(callback){
try{
  setTimeout(function(){
    if(success)
      callback(null);
    else
      callback(&apos;&#x9519;&#x8BEF;&apos;);
  },1000)
}catch(e){
  console.log(&apos;&#x6355;&#x83B7;&#x9519;&#x8BEF;&apos;,e);
}
}
</code></pre><h3 id="t85.2 &#x56DE;&#x8C03;&#x5730;&#x72F1;">5.2 &#x56DE;&#x8C03;&#x5730;&#x72F1; <a href="#t85.2 &#x56DE;&#x8C03;&#x5730;&#x72F1;"> # </a></h3>
&#x5F02;&#x6B65;&#x591A;&#x7EA7;&#x4F9D;&#x8D56;&#x7684;&#x60C5;&#x51B5;&#x4E0B;&#x5D4C;&#x5957;&#x975E;&#x5E38;&#x6DF1;&#xFF0C;&#x4EE3;&#x7801;&#x96BE;&#x4EE5;&#x9605;&#x8BFB;&#x7684;&#x7EF4;&#x62A4;<pre><code>let fs = require(&apos;fs&apos;);
fs.readFile(&apos;template.txt&apos;,&apos;utf8&apos;,function(err,template){
fs.readFile(&apos;data.txt&apos;,&apos;utf8&apos;,function(err,data){
  console.log(template+&apos; &apos;+data);
})
})
</code></pre></li>
</ul>
<h2 id="t96. &#x5F02;&#x6B65;&#x6D41;&#x7A0B;&#x89E3;&#x51B3;&#x65B9;&#x6848;">6. &#x5F02;&#x6B65;&#x6D41;&#x7A0B;&#x89E3;&#x51B3;&#x65B9;&#x6848; <a href="#t96. &#x5F02;&#x6B65;&#x6D41;&#x7A0B;&#x89E3;&#x51B3;&#x65B9;&#x6848;"> # </a></h2>
<h3 id="t106.1 &#x4E8B;&#x4EF6;&#x53D1;&#x5E03;/&#x8BA2;&#x9605;&#x6A21;&#x578B;">6.1 &#x4E8B;&#x4EF6;&#x53D1;&#x5E03;/&#x8BA2;&#x9605;&#x6A21;&#x578B; <a href="#t106.1 &#x4E8B;&#x4EF6;&#x53D1;&#x5E03;/&#x8BA2;&#x9605;&#x6A21;&#x578B;"> # </a></h3>
<p>&#x8BA2;&#x9605;&#x4E8B;&#x4EF6;&#x5B9E;&#x73B0;&#x4E86;&#x4E00;&#x4E2A;&#x4E8B;&#x4EF6;&#x4E0E;&#x591A;&#x4E2A;&#x56DE;&#x8C03;&#x51FD;&#x6570;&#x7684;&#x5173;&#x8054;</p>
<pre><code>let fs = require(&apos;fs&apos;);
let EventEmitter = require(&apos;events&apos;);
let eve = new EventEmitter();
let html = {};
eve.on(&apos;ready&apos;,function(key,value){
  html[key] = value;
  if(Object.keys(html).length==2){
    console.log(html);
  }
});
function render(){
  fs.readFile(&apos;template.txt&apos;,&apos;utf8&apos;,function(err,template){
    eve.emit(&apos;ready&apos;,&apos;template&apos;,template);
  })
  fs.readFile(&apos;data.txt&apos;,&apos;utf8&apos;,function(err,data){
    eve.emit(&apos;ready&apos;,&apos;data&apos;,data);
  })
}
render();
</code></pre><h3 id="t116.2 &#x54E8;&#x5175;&#x53D8;&#x91CF;">6.2 &#x54E8;&#x5175;&#x53D8;&#x91CF; <a href="#t116.2 &#x54E8;&#x5175;&#x53D8;&#x91CF;"> # </a></h3>
<pre><code>let fs = require(&apos;fs&apos;);

let after = function(times,callback){
  let result = {};
  return function(key,value){
    result[key] = value;
    if(Object.keys(result).length==times){
      callback(result);
    }
  }
}
let done = after(2,function(result){
  console.log(result);
});

function render(){
  fs.readFile(&apos;template.txt&apos;,&apos;utf8&apos;,function(err,template){
    done(&apos;template&apos;,template);
  })
  fs.readFile(&apos;data.txt&apos;,&apos;utf8&apos;,function(err,data){
    done(&apos;data&apos;,data);
  })
}
rende
</code></pre><h3 id="t126.3 Promise/Deferred&#x6A21;&#x5F0F;">6.3 Promise/Deferred&#x6A21;&#x5F0F; <a href="#t126.3 Promise/Deferred&#x6A21;&#x5F0F;"> # </a></h3>
<h3 id="t136.4 &#x751F;&#x6210;&#x5668;Generators/ yield">6.4 &#x751F;&#x6210;&#x5668;Generators/ yield <a href="#t136.4 &#x751F;&#x6210;&#x5668;Generators/ yield"> # </a></h3>
<ul>
<li>&#x5F53;&#x4F60;&#x5728;&#x6267;&#x884C;&#x4E00;&#x4E2A;&#x51FD;&#x6570;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x5728;&#x67D0;&#x4E2A;&#x70B9;&#x6682;&#x505C;&#x51FD;&#x6570;&#x7684;&#x6267;&#x884C;&#xFF0C;&#x5E76;&#x4E14;&#x505A;&#x4E00;&#x4E9B;&#x5176;&#x4ED6;&#x5DE5;&#x4F5C;&#xFF0C;&#x7136;&#x540E;&#x518D;&#x8FD4;&#x56DE;&#x8FD9;&#x4E2A;&#x51FD;&#x6570;&#x7EE7;&#x7EED;&#x6267;&#x884C;&#xFF0C; &#x751A;&#x81F3;&#x662F;&#x643A;&#x5E26;&#x4E00;&#x4E9B;&#x65B0;&#x7684;&#x503C;&#xFF0C;&#x7136;&#x540E;&#x7EE7;&#x7EED;&#x6267;&#x884C;&#x3002;</li>
<li>&#x4E0A;&#x9762;&#x63CF;&#x8FF0;&#x7684;&#x573A;&#x666F;&#x6B63;&#x662F;JavaScript&#x751F;&#x6210;&#x5668;&#x51FD;&#x6570;&#x6240;&#x81F4;&#x529B;&#x4E8E;&#x89E3;&#x51B3;&#x7684;&#x95EE;&#x9898;&#x3002;&#x5F53;&#x6211;&#x4EEC;&#x8C03;&#x7528;&#x4E00;&#x4E2A;&#x751F;&#x6210;&#x5668;&#x51FD;&#x6570;&#x7684;&#x65F6;&#x5019;&#xFF0C;&#x5B83;&#x5E76;&#x4E0D;&#x4F1A;&#x7ACB;&#x5373;&#x6267;&#x884C;&#xFF0C; &#x800C;&#x662F;&#x9700;&#x8981;&#x6211;&#x4EEC;&#x624B;&#x52A8;&#x7684;&#x53BB;&#x6267;&#x884C;&#x8FED;&#x4EE3;&#x64CD;&#x4F5C;&#xFF08;next&#x65B9;&#x6CD5;&#xFF09;&#x3002;&#x4E5F;&#x5C31;&#x662F;&#x8BF4;&#xFF0C;&#x4F60;&#x8C03;&#x7528;&#x751F;&#x6210;&#x5668;&#x51FD;&#x6570;&#xFF0C;&#x5B83;&#x4F1A;&#x8FD4;&#x56DE;&#x7ED9;&#x4F60;&#x4E00;&#x4E2A;&#x8FED;&#x4EE3;&#x5668;&#x3002;&#x8FED;&#x4EE3;&#x5668;&#x4F1A;&#x904D;&#x5386;&#x6BCF;&#x4E2A;&#x4E2D;&#x65AD;&#x70B9;&#x3002;</li>
<li>next &#x65B9;&#x6CD5;&#x8FD4;&#x56DE;&#x503C;&#x7684; value &#x5C5E;&#x6027;&#xFF0C;&#x662F; Generator &#x51FD;&#x6570;&#x5411;&#x5916;&#x8F93;&#x51FA;&#x6570;&#x636E;&#xFF1B;next &#x65B9;&#x6CD5;&#x8FD8;&#x53EF;&#x4EE5;&#x63A5;&#x53D7;&#x53C2;&#x6570;&#xFF0C;&#x8FD9;&#x662F;&#x5411; Generator &#x51FD;&#x6570;&#x4F53;&#x5185;&#x8F93;&#x5165;&#x6570;&#x636E;</li>
</ul>
<h4 id="t146.4.1 &#x751F;&#x6210;&#x5668;&#x7684;&#x4F7F;&#x7528;">6.4.1 &#x751F;&#x6210;&#x5668;&#x7684;&#x4F7F;&#x7528; <a href="#t146.4.1 &#x751F;&#x6210;&#x5668;&#x7684;&#x4F7F;&#x7528;"> # </a></h4>
<pre><code>function* foo () {
  var index = 0;
  while (index &lt; 2) {
    yield index++; //&#x6682;&#x505C;&#x51FD;&#x6570;&#x6267;&#x884C;&#xFF0C;&#x5E76;&#x6267;&#x884C;yield&#x540E;&#x7684;&#x64CD;&#x4F5C;
  }
}
var bar =  foo(); // &#x8FD4;&#x56DE;&#x7684;&#x5176;&#x5B9E;&#x662F;&#x4E00;&#x4E2A;&#x8FED;&#x4EE3;&#x5668;

console.log(bar.next());    // { value: 0, done: false }
console.log(bar.next());    // { value: 1, done: false }
console.log(bar.next());    // { value: undefined, done: true }
</code></pre><h4 id="t156.4.2 Co">6.4.2 Co <a href="#t156.4.2 Co"> # </a></h4>
<p><code>co</code>&#x662F;&#x4E00;&#x4E2A;&#x4E3A;<code>Node.js</code>&#x548C;&#x6D4F;&#x89C8;&#x5668;&#x6253;&#x9020;&#x7684;&#x57FA;&#x4E8E;&#x751F;&#x6210;&#x5668;&#x7684;&#x6D41;&#x7A0B;&#x63A7;&#x5236;&#x5DE5;&#x5177;&#xFF0C;&#x501F;&#x52A9;&#x4E8E;Promise&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x4F7F;&#x7528;&#x66F4;&#x52A0;&#x4F18;&#x96C5;&#x7684;&#x65B9;&#x5F0F;&#x7F16;&#x5199;&#x975E;&#x963B;&#x585E;&#x4EE3;&#x7801;&#x3002;</p>
<pre><code>let fs = require(&apos;fs&apos;);
function readFile(filename) {
  return new Promise(function (resolve, reject) {
    fs.readFile(filename, function (err, data) {
      if (err)
        reject(err);
      else
        resolve(data);
    })
  })
}
function *read() {
  let template = yield readFile(&apos;./template.txt&apos;);
  let data = yield readFile(&apos;./data.txt&apos;);
  return template + &apos;+&apos; + data;
}
co(read).then(function (data) {
  console.log(data);
}, function (err) {
  console.log(err);
});
</code></pre><pre><code>function co(gen) {
  let it = gen();
  return new Promise(function (resolve, reject) {
    !function next(lastVal) {
      let {value, done} = it.next(lastVal);
      if (done) {
        resolve(value);
      } else {
        value.then(next, reason =&gt; reject(reason));
      }
    }();
  });
}
</code></pre><h2 id="t166.5 Async/ await">6.5 Async/ await <a href="#t166.5 Async/ await"> # </a></h2>
<p>&#x4F7F;&#x7528;<code>async</code>&#x5173;&#x952E;&#x5B57;&#xFF0C;&#x4F60;&#x53EF;&#x4EE5;&#x8F7B;&#x677E;&#x5730;&#x8FBE;&#x6210;&#x4E4B;&#x524D;&#x4F7F;&#x7528;&#x751F;&#x6210;&#x5668;&#x548C;co&#x51FD;&#x6570;&#x6240;&#x505A;&#x5230;&#x7684;&#x5DE5;&#x4F5C;</p>
<h3 id="t176.5.1 Async&#x7684;&#x4F18;&#x70B9;">6.5.1 Async&#x7684;&#x4F18;&#x70B9; <a href="#t176.5.1 Async&#x7684;&#x4F18;&#x70B9;"> # </a></h3>
<ul>
<li>&#x5185;&#x7F6E;&#x6267;&#x884C;&#x5668;</li>
<li>&#x66F4;&#x597D;&#x7684;&#x8BED;&#x4E49;</li>
<li>&#x66F4;&#x5E7F;&#x7684;&#x9002;&#x7528;&#x6027;</li>
</ul>
<pre><code>let fs = require(&apos;fs&apos;);
function readFile(filename) {
  return new Promise(function (resolve, reject) {
    fs.readFile(filename, &apos;utf8&apos;, function (err, data) {
      if (err)
        reject(err);
      else
        resolve(data);
    })
  })
}

async function read() {
  let template = await readFile(&apos;./template.txt&apos;);
  let data = await readFile(&apos;./data.txt&apos;);
  return template + &apos;+&apos; + data;
}
let result = read();
result.then(data=&gt;console.log(data));
</code></pre><h3 id="t186.5.2 async &#x51FD;&#x6570;&#x7684;&#x5B9E;&#x73B0;">6.5.2 async &#x51FD;&#x6570;&#x7684;&#x5B9E;&#x73B0; <a href="#t186.5.2 async &#x51FD;&#x6570;&#x7684;&#x5B9E;&#x73B0;"> # </a></h3>
<p>async &#x51FD;&#x6570;&#x7684;&#x5B9E;&#x73B0;&#xFF0C;&#x5C31;&#x662F;&#x5C06; Generator &#x51FD;&#x6570;&#x548C;&#x81EA;&#x52A8;&#x6267;&#x884C;&#x5668;&#xFF0C;&#x5305;&#x88C5;&#x5728;&#x4E00;&#x4E2A;&#x51FD;&#x6570;&#x91CC;&#x3002;</p>
<pre><code>async function read() {
  let template = await readFile(&apos;./template.txt&apos;);
  let data = await readFile(&apos;./data.txt&apos;);
  return template + &apos;+&apos; + data;
}

// &#x7B49;&#x540C;&#x4E8E;
function read(){
  return co(function*() {
    let template = yield readFile(&apos;./template.txt&apos;);
    let data = yield readFile(&apos;./data.txt&apos;);
    return template + &apos;+&apos; + data;
  });
}
</code></pre><ul>
<li><a href="https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Statements/async_function">async_function</a>- <a href="http://www.ruanyifeng.com/blog/2015/04/generator.html">generator</a></li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
